package com.qkm.xinguan.repository.impl;


import com.qkm.xinguan.domain.entity.Comment;
import com.qkm.xinguan.repository.CommentRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.aggregation.Aggregation;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;
import org.springframework.stereotype.Service;

import java.util.List;

/**
 * @author zfj
 * @date 2021/12/28 -21:26
 */
@Service
public class CommentService {
	//注入MongoTemplate
	@Autowired
	private MongoTemplate mongoTemplate;

	//注入dao
	@Autowired
	private CommentRepository commentRepository;
	/**
	 * 保存一个评论
	 * @param comment
	 */
	public void saveComment(Comment comment){
//如果需要自定义主键，可以在这里指定主键；如果不指定主键，MongoDB会自动生成主键
//设置一些默认初始值。。。
//调用dao
		commentRepository.save(comment);
	}
	/**
	 * 更新评论
	 * @param comment
	 */
	public void updateComment(Comment comment){
//调用dao
		commentRepository.save(comment);
	}
	/**
	 * 根据id删除评论
	 * @param id
	 */
	public void deleteCommentById(String id){
//调用dao
		commentRepository.deleteById(id);
	}
	/**
	 * 查询所有评论
	 * @return
	 */
	public List<Comment> findCommentList(){
//调用dao
		return commentRepository.findAll();
	}
	/**
	 * 根据id查询评论
	 * @param id
	 * @return
	 */
	public Comment findCommentById(String id){
//调用dao
		return commentRepository.findById(id).get();
	}

	/**
	 * 根据父id查询分页列表
	 * @param parentid
	 * @param page
	 * @param size
	 * @return
	 */
	public Page<Comment> findCommentListPageByParentid(String parentid, int page , int size){
		return commentRepository.findByParentid(parentid, PageRequest.of(page-1,size));
	}

	/**
	 * 根据父商品id查询分页列表
	 * @param articleid
	 * @param page
	 * @param size
	 * @return
	 */
	public Page<Comment> findByArticleid(String articleid, int page , int size){
		return commentRepository.findByArticleid(articleid, PageRequest.of(page-1,size));
	}

	/**
	 * 点赞数+1
	 * @param id
	 */
	public void updateCommentLikenum(String id){
//查询对象
		Query query= Query.query(Criteria.where("_id").is(id));
//更新对象
		Update update=new Update();
//局部更新，相当于$set
// update.set(key,value)
//递增$inc
// update.inc("likenum",1);
		update.inc("likenum");
//参数1：查询对象
//参数2：更新对象
//参数3：集合的名字或实体类的类型Comment.class
		mongoTemplate.updateFirst(query,update,"comment");
	}

	/**
	 * 点赞数+1
	 * @param id
	 */
	public void updateCommentReplyNum(String id){
//查询对象
		Query query= Query.query(Criteria.where("_id").is(id));
//更新对象
		Update update=new Update();
//局部更新，相当于$set
// update.set(key,value)
//递增$inc
// update.inc("likenum",1);
		update.inc("replynum");
//参数1：查询对象
//参数2：更新对象
//参数3：集合的名字或实体类的类型Comment.class
		mongoTemplate.updateFirst(query,update,"comment");
	}
}
